Systeme de Gestion de 
Base de Donnees (SGBD) 



Le langage SQL, approfondissement 



I. Les operateurs logiques 

• L'operateur ALL 

Sert a comparer une valeur a toutes les valeurs d'un ensemble retourne par 
une sous-requete. 

la comparaison est vrai si elle est vraipour tous les elements de V ensemble. 

Exemple: Chercher le salarie ay ant un salaire superieur a tous les salaires 
du service n°10. 



. / 

La comparaison se fait avec tous les elements (un par un) retournes par la 
sous-requete^. 



O.Lamouchi 



2 



I. Les operateurs logiques 

• L'operateur ANY 

Sert a comparer une valeur a toute valeur applicable d'un ensemble 
retourne par une sous-requete. 

la comparaison est vrai si elle est vrai pour au moins un element de 
I 'ensemble 

Exemple: Chercher s'il y a un(e) secretaire ay ant un salaire superieur a un 
ou plusieurs ingenieurs de la societe. 



La condition est vrai des qu 'on rencontre une ligne verifiant la condition. 
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I. Les operateurs logiques 



• L'operateur EXISTS 

Permet de chercher la presence d'une ligne repondant a certains criteres 
dans une table specifique: verifie si une sous-requete retourne au moins 
une ligne. 

Exemple 1: Donner les noms des services ayant au moins un employe 
embauche apres le '01/01/05'. 
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I. Les operateurs logiques 



• L'operateur EXISTS 

Exemple 2: Donner les noms des projets dont aucun employe n'appartient 
au service FINANCE. 
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I. Les operateurs logiques 

• L'operateur EXISTS 

Exemple 2: Dormer les noms des projets dont aucun employe n'appartient 
au service FINANCE. 

SELECT titreproj 
FROM prj X 

WHERE NOT EXISTS ( SELECT * 

FROM pers Y, emprj Z 
WHERE X . pro jno=Z . pro j_pro jno 
AND Y . pno=Z . apers_pno 
AND pservno = (SELECT servno 

FROM serv 

WHERE snom= ' FINANCE ' ) ) ; 
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• L'operateur NOT EXISTS 

Permet d'obtenir la division de deux relations. 

La division de R par S sur Pattribut B (R(A,B) + S(B)) peut etre 
traduit en SQL par: 
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• L'operateur NOT EXISTS 

Exemple: Les athletes ayant participe au moins a toutes les epreuves. 



SELECT Athlete 

FROM PARTI CI PER A 

WHERE NOT EXISTS (SELECT * 

FROM EPREUVE 
WHERE NOT EXISTS 



PARTICIPER 


EPREUVE 


Athifete 


Epreuve 




Epreuve 


Dupont 


200 m 




200 m 


Dupont 


400 in 




400 m 


Dupont 


110 mH 




110 mH 


Martin 


200 m 




Martin 


400 m 




Martin 


110 mH 




Bertrand 


200 m 




Bertrand 


400 m 




Michel 


200 ni 





(SELECT * 
FROM PARTICIPER B 
WHERE ( A. Athlete=B. Athlete) 
AND ( B . Epreuve=EPREUVE . Epreuve ) 

)); 



|| ~^ Dupont et Martin 
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II. Les Requetes composees 

Une requete composee est l'association de plusieurs requetes par le biais 
d'un operateur de combinaison. 

Syntaxe: 

SELECT colonnel, colonne2 FROM TABLE 1 

WHERE conditions... 

operateur 

(SELECT colonnel, colonne2 FROM TABLE 2 
WHERE conditions...); 

Operateurs : 

UNION, 
UNION ALL, 
INTERSECT, 
MINUS . 
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II. Les Requetes composees 

• L'operateur UNION 

permet de combiner les resultats de deux instructions SELECT ou plus, 
sans retourner des lignes en double. Les colonnes selectionnees des 
differentes requetes doivent etre de meme nombre, de meme type et de 
meme ordre. 

Exemple: Donner la liste des salaries travaillant sur des projets comme 
etant employes ou responsables de projets. 

SELECT * FROM pers WHERE pno IN (SELECT Epres_pno 

FROM empr j ) ; 

UNION 

SELECT * FROM pers WHERE pno IN (SELECT Rpers_pno 

FROM pr j ) ; 
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II. Les Requetes composees 

• L'operateur UNION ALL 



Permet de combiner les resultats de deux instructions SELECT y compris 
les lignes dupliquees. Les regies qui s'appliquent a cet operateur sont les 
memes que celles qui concernent UNION. 
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II. Les Requetes composees 



• L'operateur INTERSECT 

Permet de combiner les resultats de deux instructions SELECT ou plus, 
mais ne retourne que les lignes en commun. 

Exemple: Dormer la liste des salaries qui sont a la fois affectes a des 
projets et responsables de projets. 
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III. Les objets des DB 

Un objet est une composante stockee dans la base de donnees. 

S Liste des objets d'une BD: 
Table, contrainte, 

Vue, sequence, index, procedure, . . . 
S Visualiser la liste des objets crees par un utilisateur: 
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III. Les objets des DB : Les Vues 



Une vue est une table virtuelle constitute par des sous-ensembles de 
donnees d'une ou plusieurs tables. 

S Elle est definie par une requete predefinie stockee dans la base de 
donnees. 

S Elle est exploitee comme une table mais elle ne necessite pas d'espace 
physique de stockage. 

S Vue=> fenetre dynamique, non materialisee sur les disques, par la 
quelle un utilisateur accede a la base. 



O.Lamouchi 



14 



III. Les objets des DB : Les Vues 

Utilites : 

S Pour des raisons de securite : restreindre Faeces aux donnees. 

S Conserver des donnees de syntheses afin d'eviter les requetes tres 
complexes. 

S Permettre une certaine independance des donnees. 

Presenter des differentes vues pour les memes donnees. . . 
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III. Les objets des DB : Les Vues 

• Creation (Tune vue 

- Cas (Tune vue simple (a partir d'une table). 

Syntaxe : 

\ 
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III. Les objets des DB : Les Vues 

• Creation (Tune vue 

- Cas (Tune vue simple (a partir d'une table). 

Exemple: Creer une vue des noms, postes et salaires des employes du 
service n°10. 



On peuf renommer les noms des colonnes dons lo vue en 
utilisont les olios dons lo sous-requete. 
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III. Les objets des DB : Les Vues 



Creation (Tune vue 

- Cas d'une vue complexe (a partir de plusieurs tables). 
Syntaxe : 



J 

Les vues complexes sont souvent utilisees pour la synthese des donnees. 
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III. Les objets des DB : Les Vues 



• Creation (Tune vue 

- Cas d'une vue complexe (a partir de plusieurs tables). 

Exemple : Creer une vue qui contient, pour chaque service, le nom du 
service, le nombre d'employes et le salaire moyen dans ce service. 



O.Lamouchi 



19 



III. Les objets des DB : Les Vues 

• Suppression (Tune vue 

La suppression d'une vue s'effectue de la meme fagon qu'une table: 

Drop nom_vue; 

Remarques: 

Les operations de LMD (INSERT, UPDATE, DELETE) sont aussi 
permises sur les vues, par contre les conditions suivantes doivent etre 
v erifiees : 



/ 'exemple precedent. 
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III. Les objets des DB : Les Vues 

• L'option WITH CHECK OPTION 

C'est une option de 1' instruction CREATE qui peut etre ajoutee afin que 
toutes les instructions UPDATE et INSERT repondent aux conditions de la 
definition de la vue. 



Ex emple: 



Dans ce cas, I 'option WITH CHECK OPTION refuse toute valeur NULL dans 
la colonne « commission » 
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